# Canny Edge Detector Verification Plan

#### **Team Members:**

Oluwatosin Adeosun, Sukhyun Hong, Eric Nielsen, Jiyuan Zhao

#### Design Specific Success Criteria

- Demonstrate by simulation of a Verilog test bench that the design can successfully interface with the off-chip SRAM module (both read and write capabilities).
   (1pt)
- 2. Demonstrate by simulation of a Verilog test bench that Gaussian block of the design performs the correct Gaussian convolution algorithm on the original image pixel data. (1pt)
- Demonstrate by simulation of a Verilog test bench that the Gradient/Magnitude block of the design performs the correct gradient convolution algorithm and calculates the correct magnitudes based on the data provided by the Gaussian block.
   (1pt)
- 4. Demonstrate by simulation of a Verilog test bench that the Suppression block of the design correctly calculates pixel angles, compares the angles of neighboring pixels, passes out the appropriate values based on the data provided by the Gradient/Magnitude block. (1pts)
- Demonstrate by simulation of a Verilog test bench that the Hysteresis block is able to accurately determine if pixels are/are not part of en edge using the defined thresholds and based on the data provided by the Suppression block. (1pts)
- Demonstrate by simulation of a Verilog test bench that the complete design is able to produce an output bitmap image with the edges in the original image accurately detected.
   (3pts)

### **Verification Plan Summary**

| What to<br>Verify                                            | Design<br>Module(s)<br>involved                    | Verification<br>Procedure<br>Summary                                                    | DSSC(s)<br>Proved | Use in<br>Final Demo                        | Comments                                                                                                     |
|--------------------------------------------------------------|----------------------------------------------------|-----------------------------------------------------------------------------------------|-------------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------|
| Ability to interface with off-chip SRAM                      | Memory<br>Controller,<br>Write<br>Controller       | Read in data from<br>SRAM, write<br>identical data<br>back to different<br>SRAM         | DSSC 1            | Only if<br>can't show<br>using top<br>level | Input / Output data is smaller than real image data, only for demonstration                                  |
| Correct Gaussian blur algorithm achieved                     | Gaussian<br>Block,<br>9x9 Buffer,<br>7x7 Buffer    | Compare Gaussian results to alternate implementation                                    | DSSC 2            | Only if<br>can't show<br>using top<br>level | Use MATLAB code<br>to do Gaussian<br>blur on identical<br>input data and<br>compare                          |
| Correct<br>gradient<br>calculation<br>algorithm<br>achieved  | Gradient/ Magnitude Block, 7x7 Buffer, 5x5 Buffer  | Compare gradient results to alternate implementation                                    | DSSC 3            | Only if<br>can't show<br>using top<br>level | Use MATLAB code<br>to do gradient<br>calculation on<br>identical input<br>data and compare                   |
| Correct<br>magnitude<br>calculation<br>algorithm<br>achieved | Gradient/ Magnitude Block, 7x7 Buffer, 5x5 Buffer  | Compare<br>magnitude results<br>to an alternate<br>implementation                       | DSSC 3            | Only if<br>can't show<br>using top<br>level | Use MATLAB code<br>to do magnitude<br>calculation on<br>identical input<br>data and compare                  |
| Correct suppression (edge- thinning) algorithm achieved      | Suppression<br>Block,<br>5x5 Buffer,<br>3x3 Buffer | Compare suppression results to alternate implementation                                 | DSSC 4            | Only if<br>can't show<br>using top<br>level | Use Java code to<br>do non-maximal<br>suppression on<br>identical input<br>data and compare                  |
| Correct<br>hysteresis<br>algorithm<br>achieved               | Hysteresis<br>Block,<br>3x3 Buffer                 | Compare hysteresis results to alternate implementation                                  | DSSC 5            | Only if<br>can't show<br>using top<br>level | Use MATLAB code<br>to do hysteresis<br>thresholding on<br>identical input<br>data and compare                |
| Correct<br>overall<br>functionality<br>achieved              | Top Level                                          | Compare output image to image produced by alternate canny edge detection implementation | DSSC 6            | Yes                                         | Use Python script<br>to send in bitmap<br>image to SRAM<br>and to turn output<br>back into a bitmap<br>image |

## Detailed Verification Test Breakouts Ability to Interface with Off-Chip SRAM

- Highest Level of Design Module(s) involved:
  - Memory Controller (Read), Write Controller (Write)
- Test bench Expectations/Requirements:
  - Use Python script to input pixel data (small 20x20 image) into SRAM
  - Read in data using Memory Controller
  - Immediately pass data to output module (Write Controller)
  - Write data back into different SRAM
  - Use Python script to convert pixel data back into an image
- No external or premade references are needed
- Python scripting pre/post processing is needed
- Main Verification Test Steps:
  - 1. Read in pixel data stored in SRAM
  - 2. Write data back to different SRAM
  - 3. Convert pixel data into bitmap image
  - 4. Check that output image matches input image

#### Correct Gaussian Blur Algorithm Achieved

- Highest Level of Design Module(s) involved:
  - Gaussian Block
- Test bench Expectations/Requirements:
  - o Input data stored into 9x9 buffer
  - Initial Gaussian convolution performed on right most 3 columns (3x9 block)
  - o On each clock cycle, data in the buffer is shifted by column
  - Also on each clock cycle, Gaussian convolution is performed on new data in the right most 3 columns
  - Output is 7 values (corresponding to middle 7 pixels in 3x9 block)
- No external or premade references are needed
- No pre/post processing is needed
- Main Verification Test Steps:
  - 5. Generate Gaussian output values for 9 shifts/calculations
  - 6. Capture these output values
  - 7. Generate Gaussian output values for 9 identical 3x9 blocks using MATLAB code
  - 8. Check that ASIC output values match MATLAB output values

#### Correct Gradient Calculation Algorithm Achieved

- Highest Level of Design Module(s) involved:
  - Gradient/Magnitude Block
- Test bench Expectations/Requirements:
  - Input data stored into 7x7 buffer
  - Initial gradient convolution performed on right most 3 columns (3x7 block)
  - o On each clock cycle, data in the buffer is shifted by column
  - Also on each clock cycle, gradient convolution is performed on new data in the right most 3 columns
  - Output is 5 values for Gx and 5 values of Gy (corresponding to middle 5 pixels in 3x7 block)
- No external or premade references are needed
- No pre/post processing is needed
- Main Verification Test Steps:
  - Generate gradient output values (Gx's and Gy's) for 7 shifts/calculations
  - Capture these output values
  - Generate gradient output values (Gx's and Gy's) for 7 identical 3x7 blocks using MATLAB code
  - Check that ASIC output values match MATLAB output values

#### Correct Magnitude Calculation Algorithm Achieved

- Highest Level of Design Module(s) involved:
  - Gradient/Magnitude Block
- Test bench Expectations/Requirements:
  - Input data stored into 7x7 buffer
  - Initial magnitude calculations performed on right most 3 columns (3x7 block)
  - o On each clock cycle, data in the buffer is shifted by column
  - Also on each clock cycle, magnitude calculations are performed on new data in the right most 3 columns
  - Output is 5 values for Gmag (corresponding to middle 5 pixels in 3x7 block)
- No external or premade references are needed
- No pre/post processing is needed
- Main Verification Test Steps:
  - o Generate magnitude output values (Gmag) for 7 shifts/calculations
  - Capture these output values
  - Generate magnitude output values (Gmag) for 7 identical 3x7 blocks using MATLAB code
  - Check that ASIC output values match MATLAB output values

#### Correct Suppression Calculation Algorithm Achieved

- Highest Level of Design Module(s) involved:
  - Suppression Block
- Test bench Expectations/Requirements:
  - Input data stored into three 5x5 buffers
  - Initial suppression calculations performed on right most 3 columns (3x5 block) of the Gmag buffer, using angles determined by Gx and Gy buffer values
  - o On each clock cycle, data in the buffers is shifted by column
  - Also on each clock cycle, suppression calculations are performed on new data in the right most 3 columns
  - Output is 3 values (corresponding to middle 3 pixels in 3x5 block of Gmag buffer)
- No external or premade references are needed
- No pre/post processing is needed
- Main Verification Test Steps:
  - Generate suppression output values for 5 shifts/calculations
  - Capture these output values
  - o Generate magnitude output values for 5 identical 3x5 blocks using MATLAB code
  - Check that ASIC output values match MATLAB output values

#### Correct Hysteresis Algorithm Achieved

- Highest Level of Design Module(s) involved:
  - Hysteresis Block
- Test bench Expectations/Requirements:
  - Input data stored into 3x3 buffer
  - Hysteresis calculation performed on values in the buffer
  - On each clock cycle, data in the buffer is shifted by column
  - Also on each clock cycle, hysteresis calculation is performed on the new set of data in the buffer
  - Output is 1 values (corresponding to middle 1 pixel 3x3 buffer)
- No external or premade references are needed
- No pre/post processing is needed
- Main Verification Test Steps:
  - o Generate hysteresis output value for 6 shifts/calculations
  - Capture these output values
  - o Generate hysteresis output values for 6 identical 3x3 blocks using MATLAB code
  - Check that ASIC output values match MATLAB output values

#### Correct Overall Functionality Achieved

- Highest Level of Design Module(s) involved:
  - Total Design/Chip
- Test bench Expectations/Requirements:
  - o Use Python script to store input bitmap image data into the off-chip SRAM
  - Send start signal to the chip
  - Wait for the system to complete calculations on all pixel data
  - o Use Python script to convert output image data in SRAM into bitmap image
- Use <a href="http://matlabserver.cs.rug.nl/cgi-bin/matweb.exe">http://matlabserver.cs.rug.nl/cgi-bin/matweb.exe</a> as reference for Canny Edge correctness
- Python scripting pre/post processing is needed
- Main Verification Test Steps:
  - 1. Use chip to perform Canny Edge detection algorithm on input image
  - 2. Check output bitmap image with above gold reference model
  - 3. Repeat steps 1-2 for multiple input images